Security News
Bun 1.2 Released with 90% Node.js Compatibility and Built-in S3 Object Support
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
better-color-tools
Advanced tools
Better color manipulation for Sass and JavaScript/TypeScript. Fast (75,000
ops/s) and lightweight (3.7 kB
gzip).
Supports:
npm install better-color-tools
Not all mixing algorithms are created equal. A proper color mixer requires gamma correction, something most libraries omit (even including Sass, CSS, and SVG). Compare this library’s gamma-corrected results (top) with most libraries’ default mix function:
Notice all the bottom gradients have muddy/grayed-out colors in the middle as well as clumping (colors bunch up around certain shades or hues). But fear not! better-color-utils will always give you those beautiful, perfect color transitions you deserve.
// Sass
@use 'better-color-tools' as color;
$mix: color.mix(#1a7f37, #cf222e, 0); // 100% color 1, 0% color 2
$mix: color.mix(#1a7f37, #cf222e, 0.25); // 75%, 25%
$mix: color.mix(#1a7f37, #cf222e, 0.5); // 50%, 50%
$mix: color.mix(#1a7f37, #cf222e, 0.75); // 25%, 75%
$mix: color.mix(#1a7f37, #cf222e, 1); // 0%, 100%
// JavaScript / TypeScript
import color from 'better-color-tools';
const mix = color.mix(0x1a7f37, 0xcf222e, 0); // 100% color 1, 0% color 2
const mix = color.mix(0x1a7f37, 0xcf222e, 0.25); // 75%, 25%
const mix = color.mix(0x1a7f37, 0xcf222e, 0.5); // 50%, 50%
const mix = color.mix(0x1a7f37, 0xcf222e, 0.75); // 25%, 75%
const mix = color.mix(0x1a7f37, 0xcf222e, 1); // 0%, 100%
Note: 0xcf222e
in JS is just another way of writing '#cf222e'
(replacing the #
with 0x
). Either are valid; use whichever you prefer!
To change the gamma adjustment, you can pass in an optional 4th parameter. The default gamma is 2.2
, but you may adjust it to achieve different results (if unsure, best to always omit this option).
// Sass
$gamma: 2.2; // default
$mix: color.mix(#1a7f37, #cf222e, 0, $gamma);
// JavaScript / TypeScript
const gamma = 2.2; // default
const mix = color.mix(0x1a7f37, 0xcf222e, 0, gamma);
The lighten and darken methods also use gamma correction for improved results (also better than Sass’ color.lighten()
and color.darken()
). This method is relative, so no matter what color you start with, darken(…, 0.5)
will always be
halfway to black, and lighten(…, 0.5)
will always be halfway to white.
// Sass
@use 'better-color-tools' as color;
$lighter: color.lighten(#cf222e, 0); // 0% lighter (original color)
$lighter: color.lighten(#cf222e, 0.25); // 25% lighter
$lighter: color.lighten(#cf222e, 1); // 100% lighter (pure white)
$darker: color.darken(#cf222e, 0); // 0% darker (original color)
$darker: color.darken(#cf222e, 0.25); // 25% darker
$darker: color.darken(#cf222e, 1); // 100% darker (pure black)
// JavaScript / TypeScript
import color from 'better-color-tools';
color.lighten(0xcf222e, 0); // 0% lighter (original color)
color.lighten(0xcf222e, 0.25); // 25% lighter
color.lighten(0xcf222e, 1); // 100% lighter (pure white)
color.darken(0xcf222e, 0); // 0% darker (original color)
color.darken(0xcf222e, 0.25); // 25% darker
color.darken(0xcf222e, 1); // 100% darker (pure black)
Color conversion between RGB and hexadecimal is a trivial 1:1 conversion, so this library isn’t better than any other in that regard. However, it should be noted that HSL is lossy when rounding to integers, so by default this library persists HSL decimals to prevent rounding errors when converting back-and-forth.
color.from()
takes any valid CSS string, hex number, or RGBA array (values normalized to 1
) as an input, and can generate any desired output as a result:
import color from 'better-color-tools';
color.from('rgb(196, 67, 43)').hex; // '#c4432b'
color.from('rebeccapurple').hsl; // 'hsl(270, 50%, 40%)'
Output | Type | Example |
---|---|---|
hex | string | "#ffffff" |
hexVal | number | 0xffffff |
rgb | string | "rgb(255, 255, 255)" |
rgbVal | number[] | [1, 1, 1, 1] |
rgba | string | "rgba(255, 255, 255, 1)" |
hsl | string | "hsl(360, 0%, 100%)" |
hslVal | number[] | [360, 0, 1, 1]" |
p3 | string | "color(display-p3 1 1 1)" |
Note: although this library can convert FROM a CSS color name, there is no method to convert INTO one (as over 99% of colors have no standardized name). However, you may import better-color-tools/dist/css-names.js
for an easy-to-use map for your
purposes.
This library converts sRGB to P3 “lazily,” meaning every channel is converted 1:1. This differs from some conversions which attempt to simulate hardware differences. Compare this library to colorjs.io:
P3 Color | better-color-tools | colorjs.io |
---|---|---|
1 0 0 | 255 0 0 | 250 0 0 |
For the most part, this approach makes P3 much more usable for web and is even recommended by Apple for Safari.
0.2.0
FAQs
Fast, minimal color conversion and tools for JS and Sass. Supports sRGB, Oklab, Oklch, Display P3, and more.
The npm package better-color-tools receives a total of 16 weekly downloads. As such, better-color-tools popularity was classified as not popular.
We found that better-color-tools demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Bun 1.2 enhances its JavaScript runtime with 90% Node.js compatibility, built-in S3 and Postgres support, HTML Imports, and faster, cloud-first performance.
Security News
Biden's executive order pushes for AI-driven cybersecurity, software supply chain transparency, and stronger protections for federal and open source systems.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.